package com.carrental.rental.entity;

import com.baomidou.mybatisplus.annotation.IdType;
import com.baomidou.mybatisplus.annotation.TableId;
import com.baomidou.mybatisplus.annotation.TableLogic;
import com.baomidou.mybatisplus.annotation.TableName;
import lombok.Data;

import java.io.Serializable;
import java.math.BigDecimal;
import java.time.LocalDateTime;

/**
 * 订单实体类
 */
@Data
@TableName("rental_order")
public class Order implements Serializable {

    private static final long serialVersionUID = 1L;

    /**
     * 主键ID
     */
    @TableId(value = "id", type = IdType.AUTO)
    private Long id;

    /**
     * 订单编号
     */
    private String orderNo;

    /**
     * 用户ID
     */
    private Long userId;

    /**
     * 车辆ID
     */
    private Long vehicleId;

    /**
     * 取车门店ID
     */
    private Long pickupStoreId;

    /**
     * 还车门店ID
     */
    private Long returnStoreId;

    /**
     * 租赁开始时间
     */
    private LocalDateTime startTime;

    /**
     * 租赁结束时间
     */
    private LocalDateTime endTime;

    /**
     * 租赁天数
     */
    private Integer days;

    /**
     * 租金
     */
    private BigDecimal rentAmount;

    /**
     * 押金
     */
    private BigDecimal depositAmount;

    /**
     * 优惠金额
     */
    private BigDecimal discountAmount;

    /**
     * 实际支付金额
     */
    private BigDecimal payAmount;

    /**
     * 订单状态（1-待支付，2-已支付待取车，3-用车中，4-已还车待结算，5-已完成，6-已取消）
     */
    private Integer status;

    /**
     * 支付时间
     */
    private LocalDateTime payTime;

    /**
     * 取车时间
     */
    private LocalDateTime pickupTime;

    /**
     * 还车时间
     */
    private LocalDateTime returnTime;

    /**
     * 备注
     */
    private String remark;

    /**
     * 创建时间
     */
    private LocalDateTime createTime;

    /**
     * 更新时间
     */
    private LocalDateTime updateTime;

    /**
     * 是否删除（0-未删除，1-已删除）
     */
    @TableLogic
    private Integer deleted;
} 